.PHONY: delete-unfresh-files
delete-unfresh-files:
@if [ ! -r include/xen/compile.h -o -O include/xen/compile.h ]; then \
- rm -f include/xen/{banner,compile}.h; \
+ rm -f include/xen/compile.h; \
fi
# acm_policy.h contains security policy for Xen
# compile.h contains dynamic build info. Rebuilt on every 'make' invocation.
include/xen/compile.h: LANG=C
-include/xen/compile.h: include/xen/compile.h.in include/xen/banner.h
+include/xen/compile.h: include/xen/compile.h.in
@sed -e 's/@@date@@/$(shell date)/g' \
-e 's/@@time@@/$(shell date +%T)/g' \
-e 's/@@whoami@@/$(shell whoami)/g' \
-e 's/@@extraversion@@/$(XEN_EXTRAVERSION)/g' \
-e 's!@@changeset@@!$(shell ((hg parents || head -n 7 ../ChangeLog || echo date: unavailable) | awk '{FS="changeset:[ ]+"}/^changeset/{CS=$$2};{FS="date:[ ]+"}/^date/{D=$$2}; END {print D, CS}') 2>/dev/null)!g' \
< include/xen/compile.h.in > $@.new
- @cat include/xen/banner.h >> $@.new
- @mv -f $@.new $@
-
-include/xen/banner.h:
- tools/figlet/figlet -d tools/figlet Xen $(XEN_FULLVERSION) > $@.new
+ tools/figlet/figlet -d tools/figlet Xen $(XEN_FULLVERSION) >> $@.new
@mv -f $@.new $@
include/asm-$(TARGET_ARCH)/asm-offsets.h: arch/$(TARGET_ARCH)/asm-offsets.s
# Do not depend on auto-generated header files.
HDRS := $(subst $(BASEDIR)/include/asm-$(TARGET_ARCH)/asm-offsets.h,,$(HDRS))
-HDRS := $(subst $(BASEDIR)/include/xen/banner.h,,$(HDRS))
HDRS := $(subst $(BASEDIR)/include/xen/compile.h,,$(HDRS))
# Note that link order matters!
#include <asm/sal.h>
#include <asm/meminit.h>
#include <asm/fpswa.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/acpi.h>
#include <asm/dom_fw.h>
strcpy(xsdt->oem_id, "XEN");
strcpy(xsdt->oem_table_id, "Xen/ia64");
strcpy(xsdt->asl_compiler_id, "XEN");
- xsdt->asl_compiler_revision = (XEN_VERSION<<16)|(XEN_SUBVERSION);
+ xsdt->asl_compiler_revision = (xen_major_version() << 16) |
+ xen_minor_version();
xsdt->table_offset_entry[0] = dom_pa((unsigned long) fadt);
tables->madt_ptr = dom_pa((unsigned long) madt);
strcpy(fadt->oem_id, "XEN");
strcpy(fadt->oem_table_id, "Xen/ia64");
strcpy(fadt->asl_compiler_id, "XEN");
- fadt->asl_compiler_revision = (XEN_VERSION<<16)|(XEN_SUBVERSION);
+ fadt->asl_compiler_revision = (xen_major_version() << 16) |
+ xen_minor_version();
strncpy(facs->signature, FACS_SIG, 4);
facs->version = 1;
strcpy(dsdt->oem_id, "XEN");
strcpy(dsdt->oem_table_id, "Xen/ia64");
strcpy(dsdt->asl_compiler_id, "XEN");
- dsdt->asl_compiler_revision = (XEN_VERSION<<16)|(XEN_SUBVERSION);
+ dsdt->asl_compiler_revision = (xen_major_version() << 16) |
+ xen_minor_version();
/* Trivial namespace, avoids ACPI CA complaints */
tables->aml[0] = 0x10; /* Scope */
strcpy(madt->header.oem_id, "XEN");
strcpy(madt->header.oem_table_id, "Xen/ia64");
strcpy(madt->header.asl_compiler_id, "XEN");
- madt->header.asl_compiler_revision = (XEN_VERSION<<16)|(XEN_SUBVERSION);
+ madt->header.asl_compiler_revision = (xen_major_version() << 16) |
+ xen_minor_version();
/* An LSAPIC entry describes a CPU. */
for (i = 0; i < MAX_VIRT_CPUS; i++) {
#include <asm/processor.h>
#include <xen/event.h>
#include <xen/console.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/elf.h>
#include <asm/pgalloc.h>
#include <asm/offsets.h> /* for IA64_THREAD_INFO_SIZE */
panic("can't allocate start info page");
si = page_to_virt(start_info_page);
memset(si, 0, PAGE_SIZE);
- sprintf(si->magic, "xen-%i.%i-ia64", XEN_VERSION, XEN_SUBVERSION);
+ sprintf(si->magic, "xen-%i.%i-ia64",
+ xen_major_version(), xen_minor_version());
si->nr_pages = max_pages;
si->flags = SIF_INITDOMAIN|SIF_PRIVILEGED;
#include <xen/mm.h>
#include <public/version.h>
#include <xen/gdbstub.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/console.h>
#include <xen/domain.h>
#include <xen/serial.h>
void arch_get_xen_caps(xen_capabilities_info_t info)
{
char *p=info;
+ int major = xen_major_version();
+ int minor = xen_minor_version();
- p += sprintf(p,"xen-%d.%d-ia64 ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p,"xen-%d.%d-ia64 ", major, minor);
if (vmx_enabled)
- p += sprintf(p,"hvm-%d.%d-ia64 ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p,"hvm-%d.%d-ia64 ", major, minor);
*(p-1) = 0;
#include <xen/init.h>
#include <xen/lib.h>
#include <xen/multiboot.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/spinlock.h>
#include <xen/serial.h>
#include <xen/time.h>
of_printf("%s\n", "---------------------------------------------------");
of_printf("OF: Xen/PPC version %d.%d%s (%s@%s) (%s) %s\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION,
- XEN_COMPILE_BY, XEN_COMPILE_DOMAIN,
- XEN_COMPILER, XEN_COMPILE_DATE);
+ xen_major_version(), xen_minor_version(), xen_extra_version(),
+ xen_compile_by(), xen_compile_domain(),
+ xen_compiler(), xen_compile_date());
of_printf("%s args: 0x%lx 0x%lx 0x%lx 0x%lx 0x%lx\n"
"boot msr: 0x%lx\n",
#include <xen/init.h>
#include <xen/ctype.h>
#include <xen/iocap.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <asm/processor.h>
#include <asm/papr.h>
#include "oftree.h"
printk("xen_start_info: %p\n", si);
sprintf(si->magic, "xen-%i.%i-powerpc%d%s",
- XEN_VERSION, XEN_SUBVERSION, BITS_PER_LONG, "HV");
+ xen_major_version(), xen_minor_version(), BITS_PER_LONG, "HV");
si->flags = SIF_PRIVILEGED | SIF_INITDOMAIN;
si->shared_info = ((ulong)d->shared_info) - rma;
#include <xen/config.h>
#include <xen/init.h>
#include <xen/lib.h>
-#include <xen/compile.h>
#include <asm/mpic.h>
#include "mpic_init.h"
#include "oftree.h"
#include <xen/config.h>
#include <xen/lib.h>
#include <xen/sched.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <public/xen.h>
#include "of-devtree.h"
ofd_prop_add(m, n, "name", &path[1], sizeof (path) - 1);
xl = snprintf(xen, sizeof (xen), "Xen-%d.%d%s",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION);
+ xen_major_version(), xen_minor_version(), xen_extra_version());
ASSERT(xl < sizeof (xen));
ofd_prop_add(m, n, "version", xen, xl + 1);
#include <xen/lib.h>
#include <xen/console.h>
#include <public/xen.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/sched.h>
void show_registers(struct cpu_user_regs *regs)
console_start_sync();
printk("----[ Xen-%d.%d%s ]----\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION);
+ xen_major_version(), xen_minor_version(), xen_extra_version());
printk("CPU: %08x DOMID: %08x\n",
smp_processor_id(), current->domain->domain_id);
printk("pc %016lx msr %016lx\n"
#include <xen/elf.h>
#include <xen/kernel.h>
#include <xen/domain.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/iocap.h>
#include <xen/bitops.h>
#include <asm/regs.h>
si->nr_pt_frames = nr_pt_pages;
si->mfn_list = vphysmap_start;
sprintf(si->magic, "xen-%i.%i-x86_%d%s",
- XEN_VERSION, XEN_SUBVERSION, BITS_PER_LONG, xen_pae ? "p" : "");
+ xen_major_version(), xen_minor_version(),
+ BITS_PER_LONG, xen_pae ? "p" : "");
/* Write the phys->machine and machine->phys table entries. */
for ( pfn = 0; pfn < d->tot_pages; pfn++ )
#include <xen/trace.h>
#include <xen/multiboot.h>
#include <xen/domain_page.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/gdbstub.h>
#include <xen/percpu.h>
#include <public/version.h>
void arch_get_xen_caps(xen_capabilities_info_t info)
{
char *p = info;
+ int major = xen_major_version();
+ int minor = xen_minor_version();
#if defined(CONFIG_X86_32) && !defined(CONFIG_X86_PAE)
- p += sprintf(p, "xen-%d.%d-x86_32 ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p, "xen-%d.%d-x86_32 ", major, minor);
if ( hvm_enabled )
- p += sprintf(p, "hvm-%d.%d-x86_32 ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p, "hvm-%d.%d-x86_32 ", major, minor);
#elif defined(CONFIG_X86_32) && defined(CONFIG_X86_PAE)
- p += sprintf(p, "xen-%d.%d-x86_32p ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p, "xen-%d.%d-x86_32p ", major, minor);
if ( hvm_enabled )
{
- p += sprintf(p, "hvm-%d.%d-x86_32 ", XEN_VERSION, XEN_SUBVERSION);
- p += sprintf(p, "hvm-%d.%d-x86_32p ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p, "hvm-%d.%d-x86_32 ", major, minor);
+ p += sprintf(p, "hvm-%d.%d-x86_32p ", major, minor);
}
#elif defined(CONFIG_X86_64)
- p += sprintf(p, "xen-%d.%d-x86_64 ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p, "xen-%d.%d-x86_64 ", major, minor);
if ( hvm_enabled )
{
- p += sprintf(p, "hvm-%d.%d-x86_32 ", XEN_VERSION, XEN_SUBVERSION);
- p += sprintf(p, "hvm-%d.%d-x86_32p ", XEN_VERSION, XEN_SUBVERSION);
- p += sprintf(p, "hvm-%d.%d-x86_64 ", XEN_VERSION, XEN_SUBVERSION);
+ p += sprintf(p, "hvm-%d.%d-x86_32 ", major, minor);
+ p += sprintf(p, "hvm-%d.%d-x86_32p ", major, minor);
+ p += sprintf(p, "hvm-%d.%d-x86_64 ", major, minor);
}
#else
#include <xen/config.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/domain_page.h>
#include <xen/init.h>
#include <xen/sched.h>
}
printk("----[ Xen-%d.%d%s %s ]----\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION,
+ xen_major_version(), xen_minor_version(), xen_extra_version(),
print_tainted(taint_str));
printk("CPU: %d\nEIP: %04x:[<%08x>]",
smp_processor_id(), fault_regs.cs, fault_regs.eip);
/* Find information saved during fault and dump it to the console. */
tss = &init_tss[cpu];
printk("*** DOUBLE FAULT: Xen-%d.%d%s %s\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION,
+ xen_major_version(), xen_minor_version(), xen_extra_version(),
print_tainted(taint_str));
printk("CPU: %d\nEIP: %04x:[<%08x>]",
cpu, tss->cs, tss->eip);
#include <xen/config.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/init.h>
#include <xen/sched.h>
#include <xen/lib.h>
}
printk("----[ Xen-%d.%d%s %s ]----\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION,
+ xen_major_version(), xen_minor_version(), xen_extra_version(),
print_tainted(taint_str));
printk("CPU: %d\nRIP: %04x:[<%016lx>]",
smp_processor_id(), fault_regs.cs, fault_regs.rip);
/* Find information saved during fault and dump it to the console. */
printk("*** DOUBLE FAULT: Xen-%d.%d%s %s\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION,
+ xen_major_version(), xen_minor_version(), xen_extra_version(),
print_tainted(taint_str));
printk("CPU: %d\nRIP: %04x:[<%016lx>]",
cpu, regs->cs, regs->rip);
obj-y += symbols.o
obj-y += trace.o
obj-y += timer.o
+obj-y += version.o
obj-y += vsprintf.o
obj-y += xmalloc.o
obj-$(crash_debug) += gdbstub.o
# Object file contains changeset and compiler information.
-kernel.o: $(BASEDIR)/include/xen/compile.h
+version.o: $(BASEDIR)/include/xen/compile.h
#include <xen/init.h>
#include <xen/lib.h>
#include <xen/errno.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/sched.h>
#include <xen/shadow.h>
#include <xen/guest_access.h>
{
case XENVER_version:
{
- return (XEN_VERSION<<16) | (XEN_SUBVERSION);
+ return (xen_major_version() << 16) | xen_minor_version();
}
case XENVER_extraversion:
{
xen_extraversion_t extraversion;
- safe_strcpy(extraversion, XEN_EXTRAVERSION);
+ safe_strcpy(extraversion, xen_extra_version());
if ( copy_to_guest(arg, (char *)extraversion, sizeof(extraversion)) )
return -EFAULT;
return 0;
case XENVER_compile_info:
{
struct xen_compile_info info;
- safe_strcpy(info.compiler, XEN_COMPILER);
- safe_strcpy(info.compile_by, XEN_COMPILE_BY);
- safe_strcpy(info.compile_domain, XEN_COMPILE_DOMAIN);
- safe_strcpy(info.compile_date, XEN_COMPILE_DATE);
+ safe_strcpy(info.compiler, xen_compiler());
+ safe_strcpy(info.compile_by, xen_compile_by());
+ safe_strcpy(info.compile_domain, xen_compile_domain());
+ safe_strcpy(info.compile_date, xen_compile_date());
if ( copy_to_guest(arg, &info, 1) )
return -EFAULT;
return 0;
case XENVER_changeset:
{
xen_changeset_info_t chgset;
- safe_strcpy(chgset, XEN_CHANGESET);
+ safe_strcpy(chgset, xen_changeset());
if ( copy_to_guest(arg, (char *)chgset, sizeof(chgset)) )
return -EFAULT;
return 0;
--- /dev/null
+#include <xen/compile.h>
+
+const char *xen_compile_date(void)
+{
+ return XEN_COMPILE_DATE;
+}
+
+const char *xen_compile_time(void)
+{
+ return XEN_COMPILE_TIME;
+}
+
+const char *xen_compile_by(void)
+{
+ return XEN_COMPILE_BY;
+}
+
+const char *xen_compile_domain(void)
+{
+ return XEN_COMPILE_DOMAIN;
+}
+
+const char *xen_compile_host(void)
+{
+ return XEN_COMPILE_HOST;
+}
+
+const char *xen_compiler(void)
+{
+ return XEN_COMPILER;
+}
+
+unsigned int xen_major_version(void)
+{
+ return XEN_VERSION;
+}
+
+unsigned int xen_minor_version(void)
+{
+ return XEN_SUBVERSION;
+}
+
+const char *xen_extra_version(void)
+{
+ return XEN_EXTRAVERSION;
+}
+
+const char *xen_changeset(void)
+{
+ return XEN_CHANGESET;
+}
+
+const char *xen_banner(void)
+{
+ return XEN_BANNER;
+}
obj-y += console.o
obj-y += ns16550.o
obj-y += serial.o
-
-# Object file contains changeset and compiler information.
-console.o: $(BASEDIR)/include/xen/compile.h
#include <stdarg.h>
#include <xen/config.h>
-#include <xen/compile.h>
+#include <xen/version.h>
#include <xen/init.h>
#include <xen/lib.h>
#include <xen/errno.h>
serial_set_rx_handler(sercon_handle, serial_rx);
/* HELLO WORLD --- start-of-day banner text. */
- printk(XEN_BANNER);
+ printk(xen_banner());
printk(" http://www.cl.cam.ac.uk/netos/xen\n");
printk(" University of Cambridge Computer Laboratory\n\n");
printk(" Xen version %d.%d%s (%s@%s) (%s) %s\n",
- XEN_VERSION, XEN_SUBVERSION, XEN_EXTRAVERSION,
- XEN_COMPILE_BY, XEN_COMPILE_DOMAIN,
- XEN_COMPILER, XEN_COMPILE_DATE);
- printk(" Latest ChangeSet: %s\n\n", XEN_CHANGESET);
+ xen_major_version(), xen_minor_version(), xen_extra_version(),
+ xen_compile_by(), xen_compile_domain(),
+ xen_compiler(), xen_compile_date());
+ printk(" Latest ChangeSet: %s\n\n", xen_changeset());
set_printk_prefix("(XEN) ");
if ( opt_sync_console )
--- /dev/null
+#ifndef __XEN_VERSION_H__
+#define __XEN_VERSION_H__
+
+const char *xen_compile_date(void);
+const char *xen_compile_time(void);
+const char *xen_compile_by(void);
+const char *xen_compile_domain(void);
+const char *xen_compile_host(void);
+const char *xen_compiler(void);
+unsigned int xen_major_version(void);
+unsigned int xen_minor_version(void);
+const char *xen_extra_version(void);
+const char *xen_changeset(void);
+const char *xen_banner(void);
+
+#endif /* __XEN_VERSION_H__ */